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INTRODUCTION. 

SQL (Lenguaje de Consulta Estructurado) 


El SQL (Structure Query Language), es un lenguaje de consulta 
estructurado establecido claramente como el lenguaje de alto 
nivel estandar para sistemas de base de datos relacionales. Los 
responsables de publicar este lenguaje como estandar, fueron 
precisamente los encargados de publicar estandar, la ANSI 
(Instituto Americano de Normalizacion) y la ISO (organismo 
Internacional de Normalizacion). Es por lo anterior que este 
lenguaje lo vas a encontrar en cualquiera de los DBMS 
relacionales que existen en la actualidad, por ejemplo, 
ORACLE, SYBASES, SQL SERVER por mencionar algunos. 


El SQL agrupa tres tipos de sentencias con objetivos 
particulares, en los siguientes lenguajes: 

V Lenguaje de Definicion de Datos (DDL, Data Definiton 
Language) 

V Lenguaje de Manipulation de Datos (DML, Data 
Management Language) 

V Lenguaje de Control de Datos (DCL, Data Control 
Language) 


A continuation se describen cada uno de los lenguajes: 

Lenguaje de Definicion de Datos (DDL, Data Definiton Language) 

Grupo de sentencias del SQL que soportan la definicion y 
declaration de los objetos de la base de datos. Objetos tales 
como: la base de datos misma(DATABASE), las tablas(TABLE), 
las Vistas (VIEW), los indices (INDEX), los procedimientos 
almacenados (PROCEDURE), los disparadores (TRIGGER), 
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Reglas (RULE), Dominios (Domain) y Valores por defecto 
(DEFAULT). 

CREATE, 

ALTER y 

DROP 

Lenguaje de Manipulacion de Datos (DML, Data Management 
Language) 

Grupo de sentencias del SQL para manipular los datos que 
estan almacenados en las bases de datos, a nivel de filas 
(tuplas) y/o columnas (atributos). Ya sea que se requiera que 
los datos sean modificados, eliminados, consultados o que se 
agregaren nuevas filas a las tablas de las base de datos. 

INSERT, 

UPDATE, 

DELETE y 

SELECT 

Lenguaje de Control de Datos (DCL, Data Control Language) 

Grupo de sentencias del SQL para controlar las funciones de 
administracion que realiza el DBMS, tales como la atomicidad y 
seguridad. 

COMMIT TRANSACTION, 

ROLLBACK TRANSACTION, 

GRANT 

REVOKE 
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Pasos para implementar una base de datos: 


PASO 

Descripcion 

1 

Definir en el disco duro, el area f isica que contendra las 
tablas de la base de datos. Sentencia SQL —> CREATE 
DATABASE. -> Tema 1 de este manual 

2 

Crear las diferentes tablas de la base de dato. Sentencia SQL 
—> CREATE TABLE Tema 4.2 del contenido de este curso. 

3 

Insertar las filas de las diferentes tablas, sin violar la 
integridad de datos. Sentencia SQL —> INSERT INTO . Tema 
3.4.1 del contenido de este curso. 

4 

Actualizar los datos que cambien con el tiempo en las 
diferentes tablas. Sentencia SQL —> UPDATE. Tema 3.4.2 
del contenido de este curso. 

5 

Eliminar las filas que ya no se requieran en las diferentes 
tablas. Sentencia SQL —> DELETE Tema 3.4.3 del contenido 
de este curso. 

6 

Realizar las consultas deseadas a las tablas de la base de 
datos a traves de la poderosa sentencia de consultas del SQL, 
llamada SELECT. Tema 4.3 hasta 4.6 del contenido de este 

curso. 

7 

Dar nombre a las consultas. elaboradas en el paso No.6 cuando 
se requiera ocultar el diseno y columnas de las tablas a traves 
de la creacion de vistas logicas. Sentencia SQL —> CREATE 
VIEW. Tema 3.5 del contenido de este curso. 
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Crear una base de datos: 

Sentencia SQL CREATE DATABASE 

SINTAXIS: 

create database nombre_basededatos ON PRIMARY 

( 

name = nombrejbasededatos _data, 

filename = 'c:\BDTRANSITO.mdf, /*Direccion donde se crea*/ 
size = 3mb, /*Tamano de la base de datos*/ 
maxsize = 7mb, /*Tamano de maximo de la base de datos*/ 
filegrowth = 2 mb /*crecimiento de la base de datos*/ 


log on 

( 

name = BDTRAN SITO_log, 
filename = 'c:\BDTRANSIT0.1df, 
size = 3mb, 
maxsize = 7mb, 
filegrowth = 2 mb 


Tipo de archivo 

Extension de nombre de 
archivo recomendada 

Archivo de datos principal 

.mdf 

Archivo de datos secundario 

.ndf 

Archivo de registro de transacciones 

.Idf 


Antes de proceder a crear la base de datos debemos averiguar si existe 
otra base de datos VENTAS para borrarla y crear la nuestra. Recuerde no 
utilizar estas sentecias en un servidor de production de SQL SERVER. 
Corra el siguiente codigo en el Query Analyser de SQLSERVER. 

IF DB_ID(’VENTAS’) IS NOT NULL 
BEGIN 

DROP DATABASE VENTAS 
END 

A continuation la sentencia CREATE DATABASE, que usaremos para la 
creation del espacio que contendra la base de datos Ventas es el siguiente 
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CREATE DATABASE VENTAS ON PRIMARY 

( 

NAME=VENTAS_data, 

FILENAME='c:\VENTAS.mdf, 

SIZE=5MB, 

MAXSIZE=10MB, 

FILEGROWTH=1 MB 

) 

LOG ON 

( 

NAME=VENTAS_log, 

FILENAME='c:\VENTAS.Idf, 

SIZE=5MB, 

MAXSIZE=10MB, 

FILEGROWTH=1 MB 

) 

En el ejemplo que se acaba de presentar se crea un archivo principal de 
extension mdf de tamano inicial de 5 MB, cuando este espacio se agote, 
este se expandira en 1 MB mas para tener espacio libre y meter mas 
registros o tablas y cuando se agote nuevamente el archivo fisico de 
1MB, este se expandira en 1 MB nuevamente y asi en lo sucesivo hasta 
alcanzar el maximo 10 MB ya de ahi no crecera mas. 
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Sentencia CREATE 

Dentro del Lenguaje de Definicion (DL) del SQL, la sentencia CREATE 
permiten la definicion o creacion de muchos objetos de la base de datos 
tales como: tablas (esquemas), indices, vistas, dominios, ligaduras de 
integridad y procedimientos. 

En esta oportunidad veremos las sentencias correspondientes a la creacion 
de los esquemas o lo que es lo mismo las tablas que contendran los datos 
de la base de datos, La sentencia CREATE TABLE. 


La sentencia CREATE TABLE, define el nombre de la tabla, las columnas 
con su tipo de datos, las ligaduras de intengridad que vigilan el valor que 
se guarde como dato en las columnas o atributos sean llaves o no. 


Sintaxis: 

CREATE TABLE nombre_tabla 

( 

campol tipo dato [NULL/NOT NULL] | CHECK (expresionLogica) | [ 

DEFAULT expresionConstante], 

campo2 tipo dato [NULL/NOT NULL] | CHECK (expresionLogica) | [ 

DEFAULT expresionConstante ], 

campo-N, 

PRIMARY KEY(campoJlave), 

FOREIGN KEY (campo_llave) REFERENCES tabla2 (campo_llave-tabla2) 

) 
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Ligaduras 

Esto de las ligaduras es muy importante que le presenten atencion. Ayuda 
a que dejes la vigilancia de la entrada de datos al DBMS y no al que 
programa la aplicacion que a veces puede darse que no haga tal validation 
en la entrada de los datos. Esto tiene la ventaja de ahorrar lineas de 
codigos en los programas y no te que se implementan en la sentencia SQL 
CREATE TABLE . 


Tipo: Integridad de Dominio o Columna 

Especifica un conjunto de valores que son validos a ingresar sobre una columna 
especifica para una tabla de la base de datos . Esta integridad se verifica a traves de 
una la validacion de los valores de datos que se ingresan y el tipo de los datos a 
introducir (numerico, alfanumerico, alfabetico, etc.)- 

Tipos de 
Restriccion 

Descripcion 

Clausula SQL 

Por Defecto 

Esta restriccion asigna 
un valor especifico a 
una columna cuando 
el valor para ello no 
haya sido 
explicitamente 
proporcionado para tal 
columna en una 
sentencia "INSERT" o 
de adicion de un nuevo 
registro en la tabla. 

DEFAULT 

Por ejemplo, si las reglas del negocio dicen 
que no se contratan a menores de edad, en la 
columna EDAD en la tabla EMPLEADO se 
restringe a que si una edad para un empleado 
que ingresa no es senalada explicitamente, el 
DBMS asigne 18 que es la mayoria de edad. 

CREATE TABLE EMPLEADO (ID_EMPL int 
Primary KEY, EDAD int not null default 18) 

Por Validacion 

Especifica los valores 
de datos que el DBMS 
acepta le sean 
ingresados para una 
columna. 

CHECK 

CREATE TABLE EMPLEADO (ID INT 

PRIMARY KEY, EDAD INT DEFAULT 18, SEXO 
VARCHAR(I) CHECK ( SEXO IN ('F'/M'))) 

Por ejemplo, la columna SEXO, solo permitira 
el ingreso del caracter F o M. 

Por Referencia 

Especifica los valores 
de datos que son 
aceptables para 
actualizar una columna 
y que estan basados en 
valores de datos 
localizados en una 
columna de otra tabla. 

REFERENCES 

CREATE TABLE JOBS (jobjd int primary key 
not null, funcjd int unique) 

CREATE TABLE EMPLEADO (ID INT 

PRIMARY KEY, EDAD INT DEFAULT 18, SEXO 
VARCHAR(I) CHECK ( SEXO IN ('F'/M’)) , 
NO_FUNC int REFERENCES jobs(funcjd)) 

El valor de lo que entre en la columna 
NO_FUNC en la tabla EMPLEADO debera ser 
uno de los valores contenido en la columna 
FUNCJD en la Tabla JOBS. 
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Tipo: Integridad de Entidad o Tabla 

Especifica que en una tabla o entidad, todas sus filas tenga un identificador 
unico que diferencie a una fila de otra y tambien que se establezcan columnas 
cuyo contenido es un valor unico que las hace Naves candidatas para un futuro 
como por ejemplo: numero de cedula, numero de seguro social o cuenta de e- 
mail. 

Tipos de 
Restriccion 

Descripcion 

Clausula SQL 

Por Llave 
Primaria 

Este tipo de 
restriccion se aplica 
a todas las filas 
permitiendo que 
exista un 

identificador, que se 
conoce como llave 
primaria y que se 
asegura que los 
usuarios no 
introduzcan valores 
duplicados. Ademas 
asegura que se cree 
un indice para 
mejorar el 
desempeno. Los 
valores nulos no 
estan permitidos 
para este tipo de 
restriccion. 

PRIMARY KEY 

CREATE TABLE CLIENTE (NUMCLI INT not 
null, 

NOMCLI char(30) not null, DIRCLI char(30), 
FAX INT, E MAIL CHAR(30) UNIQUE not 
null, SALD 0 30 DECIMAL (10,2), 

SALD 31 60 DECIMAL (10,2), SALD 61 90 
DECIMAL (10,2), primary key (NUMCLI)) 

En este ejemplo, NUMCLI corresponded a 
ser la Nave primaria de la tabla CLIENTE. 

Por Valor 
Unico 

Con esta restriccion 
se previene la 
duplicacion de 
valores en columnas 
que tienen valor unico 
y que no son llave 
primaria pero que 
pueden ser una llave 
alternativa o 
candidata para el 
futuro. Asegura que 
se cree (Por parte del 
DBMS) un indice para 
mejorar el 

desempeno. Y al igual 
que las Naves 
primarias, no se le 
esta permitido que se 
introduzcan valores 
nulos. 

UNIQUE 

CREATE TABLE CLIENTE (NUMCLI INT not 
null, 

NOMCLI char(30) not null, DIRCLI char(30), 
FAX INT, E MAIL CHAR(30) UNIQUE not 
null, SALD 0 30 DECIMAL (10,2), 

SALD 31 60 DECIMAL (10,2), SALD 61 90 
DECIMAL (10,2), primary key (NUMCLI)) 

En este ejemplo, E_MAIL correpondera a 
ser una columna de valores unico en la 
tabla CLIENTE 
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Tipo: Integridad Referencial 

La Integridad Referencial asegura que las relaciones que existe entre Have 
primaria (en la tabla referenciada) y la Nave foranea (en las tablas referenciantes) 
seran siempre mantenidas. Una fila o registro en la tabla referenciada (tabla 
donde reside la Nave primaria) no puede ser borrada o su Nave primaria cambiada 
si existe una fila o registro con una Have foranea (en la tabla referenciante) que 
se refiere a esa Have primaria. 

Tipos de 
Restriccion 

Description 

Clausula SQL 

Por Llave 
Foranea 

En esta restriccion se 
define una columna o 
combination de 
columnas en las 
cuales su valor debe 
corresponder al valor 
de la Have primaria 
en la misma u en otra 
tabla. 

FOREIGN KEY 

CREATE TABLE PEDIDO (NUMPED INT not 
null PRIMARY KEY, 

NUMCLI INT not null, FECHA PED 
DATETIME, 

TOT DESC DECIMAL (10,2), 

FOREIGN KEY (NUMCLI) REFERENCES 
CLIENTE(NUMCLI)) 



En este ejemplo de la creation de la tabla 
PEDIDO, la columna NUMCLI correpondera 
a ser la Have foranea que hace referecia a la 
Have primaria NUMCLI (no necesariamente 
deben llamarse igual las columnas pero 
deben tener igual tipo de datos) en la tabla 
CLIENTE 
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A continuacion se muestran las sentencias CREATE TABLE que crean las 
tab las de la Base de Datos VENTAS, de la cual ya se creo el area al 
principio de este manual. 

Es muy importante el orden en que se crean las tab las. Se debe a que no 
debe violarse la referencia cruzada entre las ligaduras de integridad del 
tipo referencial (es decir Have primaria con foraneas). Por ejemplo no puede 
crear la tabla de PEDIDO primero que la tabla de cliente, pues la tabla de 
PEDIDO hace referencia a CLIENTE. 

Primero crear las tablas que solo tienen Have primaria y luego las tablas 
que incluyen Haves foraneas. En nuestro caso, primero creamos a las 
tablas: CLIENTE, ARTICULO y VENDEDOR y despues a PEDIDO y a 

D ETALLE_PED. 
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_ Creadon de Tabla Cliente _ 

CREATE TABLE CLIENTE 
(NUMCLIINT not null, 

NOMCLI CHAR(30) not null, DIRCLI char(30), FAX INT, 
E_MAIL CHAR(30) DEFAULT ('Desconocido'), 

SALD_0_30 DECIMAL (10,2), SALD_31_60 DECIMAL (10,2), 
SALD_61_90 DECIMAL (10,2), primary key (NUMCLI)) _ 

_ Creacion de Tabla Vendedor _ 

CREATE TABLE VENDEDOR (CODVEND INT notnull” 

NOMVEND char(20) not null,APELLVEND char(20) not null, 
DIRVEND char(30), TELVEND INT, E_MAIL CHAR(30) 
DEFAULT('Desconocido'), 

CUOTA DECIMAL (10,2), VENTAS DECIMAL (10,2), primary key 
(CODVEND)) _ 

_ Creacion de Tabla Articulo _ 

CREATE TABLE ARTICULO (NUMART char(4) not null PRIMARY 
KEY, DESCRIPCION CHAR(30), PRECIO DECIMAL (10,2) NOT 
NULL CHECK (PRECIO >= 0.00), EXISTENCIA INT, 
CATEGORIA_ART CHAR (15)) 


_ Creacion de Tabla Pedido _ 

CREATE”TABLeTeDIDO (NUMPED INT not null"PRIMARY KEY, 

NUMCLI INT not null, FECHA_PED DATETIME, 

TOT_DESC DECIMAL (10,2), 

FOREIGN KEY (NUMCLI) REFERENCES CLIENTE(NUMCLI), 
FOREIGN KEY (CODVEND) REFERENCES VENDEDOR(CODVEND)) 


_ Creacion de Tabla Detalle_Ped _ 

CREATE"TABLE DETALLE_PED (NUMPED INT not null, 

NUMART char (4) not null, CANTIDAD INT CHECK (CANTTDAD >= 
0), PRIMARY KEY (NUMPED,NUMART), 

FOREIGN KEY (NUMPED) REFERENCES PEDIDO(NUMPED), 
FOREIGN KEY (NUMART) REFERENCES ARTICULO (NUMART)) 
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Eliminacion de Tablas: 

La sentencia para eliminar una tabla y por ende todo los objetos asociados 

con esa tabla como: las vistas, disparadores, etc., DROP TABLE, donde T 
es el nombre de una tabla existente. 

DROP TABLE r 

Por ejemplo si deseamos eliminar a la tabla ARTICULO_PANAMA, 
revisemos haber si esta ya existe, de la siguiete manera 

SELECT * from ARTICULO_PANAMA 

Posteriormente una vez veriifcada que la tabla existe, se procede a borrar 
la tabla, escribiendo lo siguiente en 1 ainterface de consultas del SQL: 


Sentencia ALTER 

Despues que una tabla ha sido utilizada durante algun tiempo, los 
usuarios suelen descubrir que desean almacenar informacion adicional 
con respecto a las tablas. Por ejemplo en la base de datos VENTAS , se 
podria desear: 

■S Anadir el nombre y numero de de una persona de contacto a cada 
fila de la tabla CLIENTES para contactar a los clientes. 

■S Anadir una columna de punto de reorden minimo en la tabla 
ARTICULO, para que la base de datos pueda alertar 
automaticamente cuando la cantidad o stock de un producto en 
particular esta por debajo de lo optimo para la venta. 


Por lo general, esta sentencia ALTER TABLE se utiliza sobre tablas que ya 
poseen desde cientos a miles de filas por ser tablas de un sistemas de 
Base de Datos que ya esta en production. 
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Los cambios que se pueden realizar con la sentencia SQL ALTER TABLE 
son (ver ejemplo con la figura ) : 


T1 


at 

a2 

a3 

a4 

a5 
































Tabla para ejemplos de sentencia ALTER TABLE. 

1. Anadir una definicion de la columna de una tabla. Puede crearse con 
valores nulos o valores 

ALTER TABLE nombre_de_la_tabla ADD nombre_de_columna_nueva 
TIPO DE DATO NULL 

[ CONSTRAINT nombre_de_nueva_restriccion CHECK / DEFAULT] 
Ejemplo: ALTER TABLE T1 ADD a6 VARCHAR(30) NULL 

2. Eliminar una columna de la tabla. Pero antes de su eliminacion deben 
ser eliminados por ALTER TABLE todas las restricciones que esten 
definidas sobre esta columna. 

Ejemplo: ALTER TABLE T1 DROP COLUMN a4 

3. Eliminar la definicion de: Have primaria, foranea o restricciones de 
ligaduras de integridad (check), existentes para una tabla. Esta accion no 
elimina la a la columna con sus valores, ella permanece tal cual como 
esta, solo se elimina su definicion. Este procedimiento varia de DBMS, con 
SQL SEVER, Primero se debe averiguar el nombre de la restriccion o 
ligadura de integridad (CONSTRAINT) eliminar se ejecuta el 
procedimiento almacenado SP_HELP nombre_de_Tabla y en el resultado 
se busca en la columna constraint_name a la derecha de constraint_type 
para saber el nombre que el DBMS le puso a la restriccion de Have 
primaria y luego se ejecuta la sentencia ALTER TABLE con el nombre de la 
definicion de Have primaria a eliminar. 

Ejemplo: ALTER TABLE T1 DROP CONSTRAINT 

PK_T1_numeroqueasignaelDBMS 

Esto elimina cualquiera ligadura de integridad tratada en el tema 4.2.1. 
Para verificar al ejecutar nuevamente SP_HELP nombre_de_Tabla, en el 
resultado ya no sale en constraint_type el nombre de la Have primaria. 
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4. Definir una Have primaria para una tabla. La columna(s) a la cual se le 
dara esta responsabilidad debe contener previamente valores unicos por 
fila. 

Ejemplo: ALTER TABLE T1 ADD PRIMARY KEY (al,a2) 

5. Definir una nueva Have foranea para una tabla. La columna a definir 
como Have foranea debe contener previamente valores que corresponden 
a la Have primaria de otra tabla. Es similar al descrito en Have primaria, 
solo que la palabra clave reservada es ADD FOREIGN KEY . 


6. Se puede habilitar o inhabilitar los disparadores (trigger) en una tabla. 


ALTER TABLE 

nombre_de_trigger 

nombre_de_la_tabla 

ENABLE 

TRIGGER 

ALTER TABLE 

nombre_de_trigger 

nombre_de_la_tabla 

DISABLE 

TRIGGER 


La persona que puede realizar esta operacion de alterar la tabla puede ser: 
el DBA o el creador de la tabla, u otra persona que el creador o DBA haya 
autorizado. Para la ultima situation en que a una persona se le otorga el 
permiso en la operacion, el usuario, debe calificar el nombre de la tabla 
con el nombre de su creador por delante y alterar la definition de la tabla 
de otro usuario, por ejemplo: 

ALTER TABLE nombredueno.nombretabla 
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Consultas Simples 

El corazon o poder del Lenguaje SQL es el poder hacer consultas de 
cualquier tipo a la base de datos en forma no procedural. La sentencia 
SELECT es muy poderosa y ampliamente rica en sus clausulas y 
variantes permitiendo la capacidad de atender en poco tiempo a consultas 
complejas sobre la base de datos. Esta en el especialista desarrollador de 
aplicaciones conocerlo a profundidad para explotar las bondades y 
virtudes. 

Gracias a esta sentencia es que se pueden realizar todas las operaciones 
del Algebra Relacional, tratadas en la seccion 3.2 y 3.3 del modulo III. En 
esta seccion veremos la sintaxis de como se utiliza. 

La sentencia SELECT, obtiene filas de la base de datos y permite 
realizar la selection de una o varias filas o columnas de una o 
varias tablas. 

La sintaxis completa de la instruction SELECT es compleja, pero 
la voy resumir como sigue (los corchetes cuadrados indican que la 
clausula no es obligatoria): 

SELECT nombres de las columnas 

[INTO nueva Tabla destino para resultados del selectj 

FROM origenTabla 

[WHERE condition de Busqueda] 

[GROUP BY nombres de columnas por la cual Agrupar] 

[HAVING condicionBusqueda para Group By ] 

[ORDER BY nombre de columnas [ASC | DESC] ] 


Tambien se puede unir estas sentencias con otras por el operador UNION 
entre consultas para combinar sus resultados en un sola tabla de 
resultados sin nombre. 
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Veamos cales son las funciones de cada una de las clausulas de la 
sentencia SELECT. 

La clausula SELECT: Se usa para listar las columnas de las tab las que se 
desean ver en el resultado de una consulta. Ademas de las columnas se 
pueden listas columnas a calcular por el SQL cuando actue la sentencia. 
Esta clausula no puede omitirse. 

La clausula FROM: Lista las tablas que deben ser analizadas en la 
evaluation de la expresion de la clausula WHERE y de donde se listaran 
las columnas enunciadas en el SELECT. Esta clausula no puede 
omitirse. 

La clausula WHERE: establece criterios de seleccion de ciertas filas en el 
resultado de la consulta gracias a las condiciones de busqueda. Si no se 
requiere condiciones de busqueda puede omitirse y el resultado de la 
consulta seran todas las filas de las tablas enunciadas en el FROM. 

La clausula GROUP BY: especifica una consulta sumaria. En vez de 
producir una fila de resultados por cada fila de datos de la base de datos, 
una consulta sumaria agrupa todas las filas similares y luego produce una 
fila sumaria de resultados para cada grupo de los nombres de columnas 
enunciado en esta clausula. En otras palabras, esta clausula permitira 
agrupar un conjunto de columnas con valores repetidos y utilizar las 
funciones de agregacion sobre las columnas con valores no repetidas. Esta 
clausula puede omitirse. 

La clausula HAVING: le dice al SQL que incluya solo ciertos grupos 
producidos por la clausula GROUP BY en los resultados de la consulta. Al 
igual que la clausula WHERE, utiliza una condition de busqueda para 
especificar los grupos deseados. La clausula HAVING es la encargada de 
condicionar la seleccion de los grupos en base a los valores resultantes en 
las funciones agregadas utilizadas debidas que la clausula WHERE 
condiciona solo para la seleccion de filas individuales. Esta clausula 
puede omitirse. 

La clausula ORDER BY: permitira establecer la columna o columnas sobre 
las cuales las filas resultantes de la consulta deberan ser ordenadas. 
Esta clausula puede 
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Sentencia SELECT-FROM 

El utilizar la sentencia SELECT, con estas dos clausulas SELECT - 
FROM, muestra como resultado a todas las filas existentes en las tablas 
especificadas en el FROM. 

Ejemplo # 1: Seleccionar todas las columnas y filas de la tab la CLIENTE 
SELECT * FROM CLIENTE 

Da como resultado un total de 8 filas con las 7 columnas que posee la 
tabla CLIENTE. 

Ejemplo # 2: Seleccionar columnas: nomcli y e_mail de la tabla 

CLIENTE 

SELECT NUMCLI, NOMCLI, E-MAIL FROM CLIENTE 

Da como resultado un total de 8 filas con solo 3 columnas. 

Ejemplo # 3: Este ejemplo selecciona las columnas y las muestra con el 
titulo especificado en AS, es decir con un alias. A NUMCLI lo muestra 
como NUMERO DE CLIENTE y NOMCLI lo muestra con el nombre 
especificado en el AS como NOMBRE DEL CLIENTE. Esto permite mostrar 
una columna con encabezados mas familiares a los usuarios finales. 

SELECT NUMCLI AS 'NUMERO DE CLIENTE', NOMCLI AS 
'NOMBRE DE CLIENTE' FROM CLIENTE 

Da como resultado un total de 8 filas. 

La clausula AS puede omitirse y el resultado es el mismo. 

SELECT NUMCLI 'NUMERO DE CLIENTE', NOMCLI 'NOMBRE DE 
CLIENTE’ FROM CLIENTE 

Da como resultado un total de 8 filas. 
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SENTENCIA DE FILAS DUPLICADAS (DISTINCT) 

Si una consulta incluye la Have primaria (pk) de una tabla en su lista de 
seleccion, entonces cada fila de resultados sera unica (ya que la Have 
primaria (pk) tiene un valor diferente en cada fila). Si no se incluye la Have 
primaria en los resultados, pueden producirse filas duplicadas. Veamos el 
siguiente ejemplo, 

Ejemplo # 5: Seleccionar el codigo de articulos que han sido pedidos. Sin 
usar la palabra reservada DISTINCT. 

El resultado tendria 18 filas y con codigos de productos repetidos. 

SELECT NUMART 
FROM DETALLE_PED 
ORDER BY NUMART 

Ejemplo # 6: Seleccionar el codigo de articulos que han sido pedidos. 
Utilizando la palabra reservada DISTINCT. 

El resultado contiene menos filas, 9 filas y con codigos de productos 
unicos, es decir no se repiten por las veces que fueron comprados como en 
el ejemplo #5. 

SELECT DISTINCT NUMART 
FROM DETALLE_PED 
ORDER BY NUMART 
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Columnas Calculadas 

Ademas de las columnas cuyos valores seran introducidos a la base de 
datos a traves de la sentencia INSERT, una consulta SQL puede incluir en 
su clausula SELECT columnas calculadas cuyo valor se calculan a partir 
de los valores de las otras columnas almacenadas en las tab las. Estas 
columnas, son especie de una columna virtual pues no existen fisicamente 
en la tabla y sus valores calculados corresponden a los valores por fila. 

Esta es una ventaja del SQL que evita que se tengan que disenar 
columnas calculadas fisicas en la base de datos trayendo perdida en 
almacenamiento fisico y inconsistencia por falta de mantenimiento de la 
misma. 

Ejemplo # 7: Determinar a los clientes con saldo. 

Recuerde que el saldo se encuentra almacenado en tres columnas 
diferentes: SALD_0_30 + SALD_31_60 + SALD_61_90. 

SELECT NUMCLI, NOMCLI, 

(SALD_0_30 +SALD_31_60 + SALD_61_90) as "Saldo del Cliente" 
FROM CLIENTE 

WHERE (SALD_0_30 +SALD_31_60 + SALD_61_90) <> 0 


Ejemplo # 8: Para determinar el monto de dinero que llevan acumulados 
en ventas por arriba de sus cuotas los vendedores, la consulta SELECT 
con columnas calculadas por vendedor es, 

SELECT CODVEND, NOMVEND, APELLVEND, (VENTAS - CUOTA) 
AS 'Monto por Arriba de Coutas' 

FROM VENDEDOR 

WHERE (VENTAS - CUOTA) > 0 
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Condiciones de Busqueda (=, <>, >, <, >=, <=, BETWEEN, IN, 
LIKE, IS NULL, compuestas (AND, OR, NOT)) 

SQL usa las conectivas logicas AND, OR y NOT en la clausula WHERE. 

Los operandos de las conectivas logicas pueden ser expresiones que 
contengan los operadores de comparacion <,<=,>, > =, = y <>. SQL permite 
usar los operadores de comparacion para comparar cadenas y expresiones 
aritmeticas, asi como tipos especiales, tales como el tipo fecha. 

Condiciones de Busqueda (= , <>, >, <, >=, <=): 

Ejemplo # 9: Seleccionar a los clientes cuyo numero de cliente esta 
contenido entre el rango 1309 y 1950. 

SELECT NUMCLI AS 'NUMERO DE CLIENTE', NOMCLI AS 
'NOMBRE DE CLIENTE' 

FROM CLIENTE 

WHERE NUMCLI >= 1309 AND NUMCLI <= 1950 

Se obtiene el mismo resultado utilizando la palabra reservada BETWEEN. 
Este especifica que un valor sea menor o igual que un valor y mayor o 
igual que otro valor. 


Condiciones de Busqueda con BETWEEN: 

Ejemplo # 10: Para seleccionar a los clientes cuyo numero de cliente 
esta contenido entre el rango 1309 y 1950, es: 

SELECT NUMCLI , NOMCLI FROM CLIENTE WHERE NUMCLI 
BETWEEN 1309 AND 1950 

Ejemplo # 11: Para seleccionar los clientes con nombre entre H Y P, la 
sentencia SELECT es: 

SELECT NUMCLI AS 'NUMERO DE CLIENTE', NOMCLI AS 
'NOMBRE DE CLIENTE' FROM CLIENTE 
WHERE (NOMCLI BETWEEN 'H' AND P ) 
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Condiciones de Busqueda Compuestas con AND, OR y NOT: 

Ejemplo # 12: Se puede combinar las conectivas logicas AND, OR or y 
NOT y filtrar mayor la seleccion en la consulta. Por ejemplo al seleccionar 
a los clientes cuyo numero de cliente esta contenido entre el rango 1309 y 
1950 y que han comprado o incrementado su saldo dentro del mes en 
curso, es decir su saldo en mes corriente no es cero. 

SELECT NUMCLI AS 'NUMERO DE CLIENTE', NOMCLI AS 
'NOMBRE DE CLIENTE', SALD_0_30 

FROM CLIENTE 

WHERE NUMCLI BETWEEN 1309 AND 1950 AND NOT 
SALD 0 30 = 0 


Ejemplo # 13: Utilizando el operador OR podemos buscar un cliente 
cuyo codigo dudamos si es 824 o 842. 

SELECT NOMCLI, NUMCLI FROM CLIENTE WHERE NUMCLI = 
842 OR NUMCLI = 824 

Ejemplo # 14: Para seleccionar los vendedores cuyas ventas es mayor 
que la couta que se espera deben vender y que sus ventas son superiores a 
B/8000.00. 

SELECT CODVEND, NOMVEND, APELLVEND, VENTAS, CUOTA 
FROM VENDEDOR 

WHERE VENTAS > CUOTA AND VENTAS > 8000 

Condiciones de Busqueda con LIKE: 

Ejemplo # 15: Seleccionar a todos los clientes que contengan la letra "H" 
dentro de su nombre. 

SELECT NUMCLI AS 'NUMERO DE CLIENTE', NOMCLI AS 
'NOMBRE DE CLIENTE' FROM CLIENTE WHERE NOMCLI 
LIKE '%H%' 
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Condiciones de Busqueda con la funcion SOUNDEX: 

Se emplea en situaciones donde se tiene idea del sonido de un 
valor de columna pero que no se conoce su correcta escritura (es 
una funcion nueva incorporada en el SELECT). 

Ejemplo # 16! Seleccionar a todos los clientes cuyo nombre suene 
parecido al especificado en la funcion SOUNDEX (). 

SELECT NUMCLI, NOMCLI FROM CLIENTE WHERE 
SOUNDEX (NOMCLI) = SOUNDEX ( 'DUIT ) 


Condiciones de Busqueda con IS NULL: 

Los valores de NULL crean una logica trivaluada para las 
condiciones de busqueda en SQL. Para una fila determinada, el 
resultado de una condicion de busqueda puede ser TRUE o 
FALSE, o puede ser NULL debido a que una de las columnas 
utilizadas en la evaluation de la condicion de busqueda contenga 
un valor NULL. 

A veces es util comprobar explicitamente los valores NULL en una 
condicion de busqueda y manejarias directamente. 

Ejemplo # 17: Consultar que filas de la tabla ARTICULO tienen valor 
NULL en algunas de sus columnas: DESCRIPCION, EXISTENCIA Y 
CATEGORIA_ART. 

SELECT * 

FROM ARTICULO 

WHERE DESCRIPCION IS NULL OR EXISTENCIA IS NULL OR 
CATEGORIA_ART IS NULL 
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Ordenacion de resultados de Consulta (clausula ORDER BY) 

A1 igual que las filas de una tabla en la base de datos las filas de los 
resultados de una consulta no estan dispuestas en ningun orden 
particular. Existen situaciones en la que es necesario ver la informacion en 
un orden en especial, como en orden alfabetico (ASC, ascendente) u ver a 
las cifras de dinero listadas de mayor monto a menor (DESC, 
descendente). Se puede pedir a SQL que ordene los resultados de una 
consulta incluyendo la clausula ORDER BY en la sentencia SELECT. 

Ejemplo #18: Para buscar la informacion de los vendedores por orden de 
su apellido o nombre, la sentencia select con la clausula ORDER BY seria 
la siguiente: 

SELECT * 

FROM VENDEDOR 
ORDER BY APELLVEND 

Ejemplo # 19: Para determinar en una lista resultante del ejemplo #8, 
quien el nombre del vendedor con mayor el monto de dinero es 
conveniente ordenar por esta que llevan acumulados en ventas por arriba 
de sus cuotas los vendedores, la consulta SELECT con columnas 
calculadas por vendedor es, 

SELECT CODVEND, NOMVEND, APELLVEND, (VENTAS - CUOTA) 
AS 'Monto por Arriba de Coutas' 

FROM VENDEDOR 

WHERE (VENTAS - CUOTA) > 0 

ORDER BY (VENTAS - CUOTA) DESC 
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Consultas a Multiples Tablas 

Generalmente el poder de la sentencia SELECT se basa en su 
capacidad de poder en una sola sentencia consultar multiples 
tablas simultaneamente. Esta operation tambien se le llama 
JOIN y es lo que en particular llamo un "pegue de tablas en 
forma horizontal" y ocurre gracias a que existen columnas de 
conexion osea atributos de asociacion comunes en las tablas que 
se unen en esta forma, vea figura: 
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Para que se puedan realizar consultas a multiples tablas el requisito 
principal es que las tablas a reunirse en una consulta tengan columnas 
con valores o dominios comunes, es decir columna de conexion. Si 
reunimos a las tablas de la figura 4.4.a, de tal forma que la Tablal se 
reuna con la Tabla2 y la Tabla2 se reuniera con la Tabla3, el requisito 
indispensable seria: la Tablal debe tener una columna comun en la 
Tabla2 y Tabla2 debe tener una columna de conexion en la Tabla3. Por lo 
general estas columnas comunes son: en una tab la la columna es la Have 
primaria y en la otra tabla la columna asociada es la Have foranea que 
referencia a la primaria. Para este tipo de consultas a multiples tablas la 
clausula FROM es la responsable de indicar cual sera la(s) tabla(s) fuentes. 

Existen dos formas de sintaxis permitidas para la escritura de la 
sentencia SELECT para la reunion de tablas, basada en la figura 4.4.a, 
estas formas son las siguientes: 

FORMA 1: 

SELECT al, a2, a5, bl, b2, b3, cl, c2, c3 
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FROM Tablal, Tabla2, Tabla3 

WHERE Tablal.al = Tabla2.b2 AND Tabla2. bl = Tabla3.cl 
FORMA 2: 

SELECT al, a2, a5, bl, b2, b3, cl, c2, c3 
FROM Tablal INNER JOIN Tabla2 ON Tablal.al = Tabla2.b2 
INNER JOIN Tabla3 Tabla2. b 1 = Tabla3. c 1 


Note que las columnas comunes en ambas tab las han de calificarse con el 
nombre de la tab la que pertenecen para evitar errores de ambiguedad. 


La Forma 2, tiene la ventaja de liberar a la clausula WHERE y dejar esta 
para filtros especificos sobre las filas resultan tes de la reunion de tab las. 
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Ejemplo #21: Si se desea unir la tabla de CLIENTES con PEDIDO (ver 
figura 4.4.b.), para ambas tablas, la columna de conexion es NUMCLI, la 
consulta SELECT que realiza esta reunion es la siguiente: 

FORMA 1: 

SELECT CLIENTE.NUMCLI, NOMCLI, NUMPED, FECHA_PED, TOT_DESC 
FROM CLIENTE, PEDIDO 

WHERE CLIENTE.NUMCLI = PEDIDO.NUMCLI 
FORMA 2: 

SELECT CLIENTE.NUMCLI, NOMCLI, NUMPED, FECHA_PED, TOT_DESC 
FROM CLIENTE INNER JOIN PEDIDO 
ON CLIENTE.NUMCLI = PEDIDO.NUMCLI 

Ejemplo # 24: Seleccionar todos los pedidos con su informacion completa, 
esto incluye: datos del cliente, datos del pedido, datos del detalle de la 
compra, datos del articulo de la compra y datos den vendedor que atendio 
el pedido. Esta consulta requiere que se realice la union (join) de las 
cinco tablas: Cliente, Pedido, Detalle_Ped , Articulo y Vendedor, que son 
todas las tablas de la base de datos del VENTAS. 

SELECT PEDIDO.NUMPED, CLIENTE.NUMCLI,NOMCLI,DIRCLI, 

APELLVEND AS VENDEDOR, FECHA_PED,ARTICULO.NUMART, 
DESCRIPCION,PRECIO,CANTIDAD,(PRECIO*CANTIDAD) AS TOTAL 
FROM CLIENTE INNER JOIN PEDIDO ON CLIENTE.NUMCLI=PEDIDO.NUMCLI 
INNER JOIN DETALLE_PED ON PEDIDO.NUMPED = DETALLE_PED.NUMPED 
INNER JOIN ARTICULO ON DETALLE_PED.NUMART=ARTICULO.NUMART 
INNER JOIN VENDEDOR ON PEDIDO.CODVEND = VENDEDOR.CODVEND 
ORDER BY PEDIDO.NUMPED 
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RESULTADO: 

HUMPED HUMCLI HOMCLI DIRCLI VEHDEDOR FECHA PED HUMART DESCRJPCIC 


101448 

836 


Holiday Inn Downtown 

10 Downey Stre 

Torres 

10-Nov-99 

A38 

Velas Aromati 

101448 

836 


Holiday Inn Downtown 

10 Downey Stre 

Torres 

10-Nov-99 

F251 

Raqueta de Te 

101448 

836 


Holiday Inn Downtown 

10 Downey Stre 

Torres 

10-Nov-99 

S247 

Tornillos 3/4 

101449 

812 


Haper University 

33Whipple Lane 

Ramirez 

14-Nov-99 

B14 

Toallas 

101450 

812 


Haper University 

33Whipple Lane 

Medina 

15-Nov-99 

Cl 18 

Sabanas 

101451 

1319 


McGraw Manufacturing 

98 Main, Endicol 

Pinion 

18-Nov-99 

Cl 18 

Sabanas 

101451 

1319 


McGraw Manufacturing 

98 Main, Endicol 

Pinion 

18-Nov-99 

Dll 7 

Tacos 3/4 

101452 

812 


Haper University 

33Whipple Lane 

Martinez 

21-Nov-99 

A38 

Velas Aromati 

101452 

812 


Haper University 

33Whipple Lane 

Martinez 

21-Nov-99 

B16 

Cobija 

101452 

812 


Haper University 

33Whipple Lane 

Martinez 

21-Nov-99 

F251 

Raqueta de Te 

101453 

836 


Holiday Inn Downtown 

10 Downey Stre 

Prado 

28-Nov-99 

N38 

Servilletas 

101453 

836 


Holiday Inn Downtown 

10 Downey Stre 

Prado 

28-NOV-99 

T101 

Manteles 

101454 

824 


Hara Enterprises 

Commerce Circli 

Jimenez 

30-Nov-99 

B14 

Toallas 

101456 

812 


Haper University 

33Whipple Lane 

Prado 

01 -Dic-99 

B14 

Toallas 

101456 

812 


Haper University 

33Whipple Lane 

Prado 

01 -Dic-99 

B16 

Cobija 

101456 

812 


Haper University 

33Whipple Lane 

Prado 

01 -Dic-99 

Cl 18 

Sabanas 

101456 

812 


Haper University 

33Whipple Lane 

Prado 

01 -Dic-99 

T101 

Manteles 

101457 

2107 


Union Hospital 

1021 6th Avenu 

Pinion 

02-Dic-99 

Cl 18 

Sabanas 
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Consultas Resumen 

Estas consultas resultan ventajosas para hacer busquedas a nivel 
de los valores de las columnas a nivel de todas las filas. Por 
ejemplo si se desea saber en una tabla de 10,000 filas: el mayor 
saldo adeudado, la cuota minima o maxima asignada a los 
vendedores, el tamano promedio de pedidos, el total de clientes o 
vendedores (es decir total de filas). 

Ejemplo #27: Determinar en una misma consulta lo siguiente: 

• Total de Vendedores. COUNT (NOMVEND) 

• Monto Total de COUTAS que deben alcanzarse entre todos los 
vendedores. SUM (CUOTA). 

• El monto promedio de cuotas asignado a un vendedor. AVG(COUTA) 

• El valor de la cuota maxima asignado al un vendedor. MAX(COUTA) 

• El valor de la cuota minima asignado a un vendedor. MIN (COUTA) 

SENTENCIA SQL: 

USE VENTAS 

SELECT COUNT (NOMVEND)AS "TOTAL VENDEDORES", 

SUM (CUOTA) "MONTO DE CUOTAS", AVG(CUOTA) AS "CUOTA 
PROMEDIO", MAX(CUOTA) "CUOTA MAX.", MIN (CUOTA) "CUOTA MIN." 
FROM VENDEDOR 

El resultado de esta consulta es una fila con los siguientes valores: 

TOTAL VENDEDORES MONTO DE CUOTAS CUOTA PROMEDIO CUOTA MAX. 
CUOTA MIN. 


10 25341.00 2534.10 

8705.00 200.00 

Otros ejemplos: 

Sentencia SUM: 

SELECT SUM (cantidad) as 'Suma de las Cantidades' FROM detalle_ped 

Sentencia AVG: 

SELECT AVG (cantidad) as 'Cantidad Promedio Pedida' FROM detalle_ped 
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Sentencia MIN: 

SELECT MIN (cantidad) as 'Cantidad Minimo Pedida' FROM detalle_ped 

Sentencia MAX: 

SELECT MAX (cantidad) as 'Cantidad Maxima Pedida' 

FROM detalle_ped 

Sentencia COUNT 

SELECT COUNT (*) as 'Total de Clientes' FROM CLIENTE 

Sentencia DISTINCT 

SELECT COUNT(DISTINCT numped) as 'Total de Pedidos Solicitados' 
FROM detalle_ped 

En esta ultima consulta hace que los numeros de pedidos en 
DETALLE__PED , que son repetidos, la clausula DISTINCT cuente solo 
numeros de uno de los que se repiten. 
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CONCLUSION 

Este manual fue hecho con el proposito de ayudar a los 
estudiantes universitarios que tienen un deseo de aprender, 
mas fuerte cada dia. 

Tambien para ayudarme a mi mismo en la codificacion de SQL. 

Cualquier comentario o sugerencia (constructivas claro), me lo 
pueden hacer a mi correo electronico: 

alvaroegarcia@ubbi.com 

alvaroegarcia@iespana.es 


FECHA DE CREACION: 

Lunes 24 de noviembre de 2003 
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